import { PlusOutlined } from '@ant-design/icons';
import { Button, Divider, message, Popconfirm, Image } from 'antd';
import React, { useState, useRef } from 'react';
import { PageContainer, FooterToolbar } from '@ant-design/pro-layout';
import ProTable from '@ant-design/pro-table';
import CreateForm from './components/CreateForm';
import FormItem from 'antd/lib/form/FormItem';
import UploadImg from '@/components/UploadImg';
import { queryRule, updateRule, addRule, removeRule } from './service';
import styles from '../../../global.less';
/**
 * 添加节点
 *
 * @param fields
 */

const handleAdd = async (fields) => {
  const hide = message.loading('正在添加');

  try {
    await addRule({ ...fields });
    hide();
    message.success('添加成功');
    return true;
  } catch (error) {
    hide();
    message.error('添加失败请重试！');
    return false;
  }
};
/**
 * 更新节点
 *
 * @param fields
 */

const handleUpdate = async (fields) => {
  const hide = message.loading('正在配置');

  try {
    await updateRule(fields);
    hide();
    message.success('配置成功');
    return true;
  } catch (error) {
    hide();
    message.error('配置失败请重试！');
    return false;
  }
};
/**
 * 删除节点
 *
 * @param selectedRows
 */

const handleRemove = async (selectedRows, actionRef) => {
  const hide = message.loading('正在删除');
  if (!selectedRows) return true;

  try {
    await removeRule(selectedRows);
    hide();
    message.success('删除成功，即将刷新');
    actionRef.current.reload();
    return true;
  } catch (error) {
    hide();
    message.error('删除失败，请重试');
    return false;
  }
};

const TableList = () => {
  const [createModalVisible, handleModalVisible] = useState(false);
  const [updateState, handleUpdateState] = useState(false);
  const [stepFormValues, setStepFormValues] = useState({});
  const actionRef = useRef();
  const [count, setCount] = useState();
  const [selectedRowsState, setSelectedRows] = useState([]);
  const [facePicture, setFacePicture] = useState(null);
  const handleSetFacePicture = (payload) => {
    setFacePicture(payload.url);
  };
  const columns = [
    {
      title: '品牌名称',
      dataIndex: 'name',
      formItemProps: {
        rules: [
          {
            required: true,
            message: '品牌名称为必填项',
          },
        ],
      },
      render: (dom, entity) => {
        return <a>{dom}</a>;
      },
    },
    {
      title: '品牌简介',
      hideInSearch: true,
      dataIndex: 'remark',
    },
    {
      title: '品牌logo',
      dataIndex: 'logo',
      hideInSearch: true,

      render: (_, record) => {
        return <Image className={styles.img_div} src={_} />;
      },
      renderFormItem: (item, { defaultRender, ...rest }, form) => {
        return (
          <>
            {stepFormValues ? (
              <FormItem name="icon">
                <UploadImg
                  imgUrl={facePicture}
                  showImgUrl={facePicture}
                  subpath="brand"
                  handleSetFacePicture={handleSetFacePicture}
                />
              </FormItem>
            ) : (
              <FormItem name="icon">
                <UploadImg subpath="brand" handleSetFacePicture={handleSetFacePicture} />
              </FormItem>
            )}
          </>
        );
      },
    },
    {
      title: '操作',
      dataIndex: 'option',
      valueType: 'option',
      render: (_, record) => {
        return (
          <>
            <a
              onClick={() => {
                handleUpdateState(true);
                handleModalVisible(true);
                setStepFormValues(record);
                setFacePicture(record.logo);
              }}
            >
              修改
            </a>
            <Divider type="vertical" />
            <Popconfirm
              placement="top"
              title="确定要删除吗?"
              onConfirm={() => {
                handleRemove(record.id, actionRef);
              }}
              okText="确定"
              cancelText="取消"
            >
              <a>删除</a>
            </Popconfirm>
          </>
        );
      },
    },
  ];
  return (
    <PageContainer>
      <ProTable
        headerTitle="品牌列表"
        actionRef={actionRef}
        rowKey="id"
        bordered
        search={{
          labelWidth: 120,
        }}
        toolBarRender={() => [
          <Button
            type="primary"
            onClick={() => {
              handleUpdateState(false);
              handleModalVisible(true);
              setFacePicture();
              queryRule({})
            }}
          >
            <PlusOutlined /> 新建
          </Button>,
        ]}
        request={(params, sorter, filter) => queryRule({ ...params, sorter, filter })}
        columns={columns}
        postData={(payload) => {
          const { list, total } = payload;
          setCount(total);
          return list||[];
        }}
        pagination={{
          defaultPageSize: 30,
          showSizeChanger: false,
          showTitle: false,
          total: count,
          showTotal: (total) => `共${total}条`,
        }}
      />

      <CreateForm
        width={800}
        title={updateState ? '修改品牌' : '新建品牌'}
        onCancel={() => handleModalVisible(false)}
        modalVisible={createModalVisible}
      >
        <ProTable
          className={styles.formModal}
          onSubmit={async (value) => {
            value.logo = facePicture;
            updateState ? (value.id = stepFormValues.id) : null;
            const success = updateState ? await handleUpdate(value) : await handleAdd(value);
            if (success) {
              handleModalVisible(false);
              if (actionRef.current) {
                actionRef.current.reload();
              }
            }
          }}
          rowKey="id"
          bordered
          type="form"
          form={{
            initialValues: updateState === true ? stepFormValues : null,
            layout: 'horizontal ',
            labelAlign: 'rihgt',
            labelCol: { span: 8 },
            wrapperCol: { span: 24 },
          }}
          columns={columns}
        />
      </CreateForm>
    </PageContainer>
  );
};

export default TableList;
